

# **ECTM** Interface Specification

Document Number: MD00052 Revision 1.05 February 25, 2002

MIPS Technologies, Inc. 1225 Charleston Road Mountain View, CA 94043-1353

Copyright © 2000-2002 MIPS Technologies Inc. All right reserved.

Copyright © 2000-2002 MIPS Technologies, Inc. All rights reserved.

Unpublished rights reserved under the Copyright Laws of the United States of America.

This document contains information that is proprietary to MIPS Technologies, Inc. ("MIPS Technologies"). Any copying, reproducing, modifying, or use of this information (in whole or in part) which is not expressly permitted in writing by MIPS Technologies or a contractually-authorized third party is strictly prohibited. At a minimum, this information is protected under unfair competition and copyright laws. Violations thereof may result in criminal penalties and fines.

MIPS Technologies or any contractually-authorized third party reserves the right to change the information contained in this document to improve function, design or otherwise. MIPS Technologies does not assume any liability arising out of the application or use of this information, or of any error of omission in such information. Any warranties, whether express, statutory, implied or otherwise, including but not limited to the implied warranties of merchantability or fitness for a particular purpose, are excluded. Any license under patent rights or any other intellectual property rights owned by MIPS Technologies or third parties shall be conveyed by MIPS Technologies or any contractually-authorized third party in a separate license agreement between the parties.

The information contained in this document shall not be exported or transferred for the purpose of reexporting in violation of any U.S. or non-U.S. regulation, treaty, Executive Order, law, statute, amendment or supplement thereto.

The information contained in this document constitutes one or more of the following: commercial computer software, commercial computer software documentation or other commercial items. If the user of this information, or any related documentation of any kind, including related technical data or manuals, is an agency, department, or other entity of the United States government ("Government"), the use, duplication, reproduction, release, modification, disclosure, or transfer of this information, or any related documentation of any kind, is restricted in accordance with Federal Acquisition Regulation 12.212 for civilian agencies and Defense Federal Acquisition Regulation Supplement 227.7202 for military agencies. The use of this information by the Government is further restricted in accordance with the terms of the license agreement(s) and/or applicable contract terms and conditions covering this information from MIPS Technologies or any contractually-authorized third party.

MIPS<sup>®</sup>, R3000<sup>®</sup>, R4000<sup>®</sup>, R5000<sup>®</sup> and R10000<sup>®</sup> are among the registered trademarks of MIPS Technologies, Inc. in the United States and certain other countries, and MIPS16<sup>TM</sup>, MIPS16e<sup>TM</sup>, MIPS32<sup>TM</sup>, MIPS64<sup>TM</sup>, MIPS-3D<sup>TM</sup>, MIPS-based<sup>TM</sup>, MIPS II<sup>TM</sup>, MIPS III<sup>TM</sup>, MIPS III<sup>TM</sup>, MIPS IV<sup>TM</sup>, MIPS V<sup>TM</sup>, MDMX<sup>TM</sup>, SmartMIPS<sup>TM</sup>, 4K<sup>TM</sup>, 4Kc<sup>TM</sup>, 4Km<sup>TM</sup>, 4Ke<sup>TM</sup>, 4KEc<sup>TM</sup>, 4KEp<sup>TM</sup>, 4KEp<sup>TM</sup>, 4KSc<sup>TM</sup>, 5K<sup>TM</sup>, 5Kc<sup>TM</sup>, 5Kf<sup>TM</sup>, 20K<sup>TM</sup>, 20Kc<sup>TM</sup>, R20K<sup>TM</sup>, R4300<sup>TM</sup>, ATLAS<sup>TM</sup>, CoreLV<sup>TM</sup>, EC<sup>TM</sup>, JALGO<sup>TM</sup>, MALTA<sup>TM</sup>, MGB<sup>TM</sup>, SEAD<sup>TM</sup>, SEAD-2<sup>TM</sup>, SOC-it<sup>TM</sup> and YAMON<sup>TM</sup> are among the trademarks of MIPS Technologies, Inc.

All other trademarks referred to herein are the property of their respective owners.

## Table of Contents

| 1.1 Features         1.2 Basic Operation         2 Signal List         3 Timing Diagrams         3.1 Single Read Transactions         3.2 Single Write Transactions         3.3 Back-to-back Read Transactions         3.4 Back-to-back Write Transactions         3.5 Read Transaction Followed by a Write Transaction | 5<br>6<br>9<br>9 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| <ul> <li>2 Signal List</li></ul>                                                                                                                                                                                                                                                                                        | 6<br>9<br>9      |
| <ul> <li>2 Signal List</li></ul>                                                                                                                                                                                                                                                                                        | 6<br>9<br>9      |
| <ul> <li>3.1 Single Read Transactions</li></ul>                                                                                                                                                                                                                                                                         | 9                |
| <ul> <li>3.1 Single Read Transactions</li></ul>                                                                                                                                                                                                                                                                         | 9                |
| <ul> <li>3.2 Single Write Transactions</li></ul>                                                                                                                                                                                                                                                                        |                  |
| <ul><li>3.3 Back-to-back Read Transactions</li><li>3.4 Back-to-back Write Transactions</li></ul>                                                                                                                                                                                                                        | .13              |
|                                                                                                                                                                                                                                                                                                                         | .17              |
| 3.5 Read Transaction Followed by a Write Transaction                                                                                                                                                                                                                                                                    |                  |
|                                                                                                                                                                                                                                                                                                                         | .20              |
| 3.6 Write Transaction Followed by a Read Transaction                                                                                                                                                                                                                                                                    | .22              |
| 3.7 Burst Transactions                                                                                                                                                                                                                                                                                                  | .25              |
| 4 External Write Buffers                                                                                                                                                                                                                                                                                                |                  |
| A Endianess                                                                                                                                                                                                                                                                                                             |                  |
| B Lower Address Bit Generation                                                                                                                                                                                                                                                                                          | .34              |
| C Revision History                                                                                                                                                                                                                                                                                                      | .35              |

## ECTM Interface Specification

#### **1** Introduction

This document describes the EC<sup>TM</sup> interface designed for microprocessor cores. All MIPS cores implementing the EC interface comply to this specification. Implementation-specific details can be found in the documentation accompanying the core.

Use the EC interface to attach memory controllers, memory-mapped I/Os, etc. A bus controller must be included in cases where multiple slaves connect to the EC interface. Figure 1 shows an example of the EC interface placement within a system.



Figure 1 Example of the EC Interface in a System

#### 1.1 Features

The EC interface has the following features:

- 32 or 64-bit data buses
- · 36-bit addressing
- Separate read and write data buses
- All signals are unidirectional—no bidirectional or 3-state buses
- · Fully registered, synchronous interface to the master
- · Separate read and write bus error indications
- · Separate address and data phases allow pipelining on the interface
- No limit on the number of outstanding transactions
- Number of outstanding transactions can be limited by the slave
- Support for variable burst length
- · Sequential or sub-block ordering burst address sequences
- · Indication of first and last address phase of a burst
- Request for emptying external write buffers and indication of external write buffers being empty
- Byte enable indication

#### EC<sup>™</sup> Interface Specification, Revision 1.05

#### Copyright © 2000-2002 MIPS Technologies Inc. All right reserved.

- Indication of instruction read (fetch)
- Address and data phases can complete the same cycle they are initiated (zero wait states)
- No limit on the number of wait states in address and data phases
- Independent read and write data phases. A read transaction can overtake a write transaction and vice versa.
- Only one master and one slave

#### **1.2 Basic Operation**

All inputs to the master are sampled at the rising edge of the Clock signal. Further the outputs from the master change with respect to a rising edge of the Clock signal.

The EC interface does not include a signal to indicate reset. Therefore to reset the EC interface, reset the master and the slave simultaneously. Whenever the EC interface is reset, all transactions are aborted and the bus returns to the idle state. EB\_ARdy, EB\_AValid, EB\_WDRdy, EB\_RdVal, EB\_Burst, EB\_BFirst, EB\_BLast, EB\_RBErr, and EB\_WBErr must be driven inactive during reset.

Each transaction on the EC interface has an address phase and a data phase, which can have a number of wait states.

A wait state in the address phase is named an *address wait state* and is defined as a clock cycle where EB\_AValid is asserted and EB\_ARdy was sampled deasserted in the beginning of the cycle.

An address phase begins in the clock cycle where the master asserts EB\_AValid. An address phase ends on the positive clock edge following an asserted sample of EB\_ARdy. For maximum speed (no address wait states), EB\_ARdy has to be sampled asserted on the positive clock edge preceding the beginning of the address phase. During an address phase, all signals driven by the master are unchanged and stable (except from the write data bus, EB\_WData).

Due to the separate read and write data buses, two types of data phases exist: the read data phase and the write data phase.

A wait state in a data phase is named a *data wait state*. It is defined as a clock cycle where the corresponding address phase has been started (and possibly ended) and:

- For a write data phase, EB\_WDRdy is sampled deasserted at the beginning of the cycle
- For a read data phase, EB\_RdVal is sampled deasserted at the end of the cycle

A read data phase begins in the clock cycle where the master starts the corresponding read address phase. However, if there are outstanding read data phases when the read address phase begins, the corresponding read data phase does not start until all of the preceding read data phases have ended. The read data phase ends at the positive clock edge where EB\_RdVal is sampled asserted. It can not end earlier than when the corresponding address phase ends.

A write data phase begins in the clock cycle where the master starts the corresponding write address phase. However, if there are outstanding write data phases when the write address phase begins, the corresponding write data phase does not start until all of the preceding write data phases have ended. The write data phase ends at the positive clock edge following the positive clock edge where EB\_WDRdy is sampled asserted. For maximum speed (no data wait states), EB\_WDRdy must be asserted on the positive clock edge preceding the beginning of the corresponding address phase. It cannot end earlier than the corresponding address phase ends.

From these definitions, for a given transaction the number of data wait states must be greater than or equal to the number of address wait states.

## 2 Signal List

Table 2 lists all of the EC interface signals in alphabetical order. Table 1 defines the signal directions.

| Dir | Description                                                                                                                                  |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------|
| Ι   | Input to the master. Unless otherwise noted, input signals are sampled on the rising edge of the appropriate CLK signal.                     |
| 0   | Output from the master. Unless otherwise noted,<br>output signals are driven on the rising edge of the<br>appropriate CLK signal.            |
| SI  | Static input to the master. These signals are normally tied to either power or ground and should not change state while RESET is deasserted. |

## Table 1 Signal Direction Key

#### Table 2 EC Interface Signals

| Signal Name | Dir | Description                                                                                                                                                                                                                               |
|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EB_A[35:2]  | 0   | Address bus. Only valid when EB_AValid is asserted. Note that only EB_A[35:3] address lines are used in 64-bit implementations.                                                                                                           |
| EB_ARdy     | Ι   | Assertion of this signal indicates whether the slave is ready for a new address.<br>The master does not complete the address phase until the clock cycle after<br>EB_ARdy is sampled asserted.                                            |
| EB_AValid   | 0   | Assertion of this signal indicates that the values on the address bus and access type lines are valid (signifying an address phase is ongoing). EB_AValid is always valid and cannot be deasserted between address phases within a burst. |

|   |                                                                                                                                                                                                                             | Des                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | scription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0 | data phase corr<br>asserted, the ass<br>while EB_AVa<br>During bursts a<br>During single t<br>the default one<br>makes it possib<br><b>Byte</b> 0<br>00000001<br>00010000<br>11000000<br>11100000<br>11110000<br>111111     | responding to the curr<br>sociated byte is being<br>lid is asserted.<br>all lines must be asser<br>ransactions, if the ma<br>s listed in the two table<br>ble to force it into usin<br>enables supported by d<br>00000010<br>00110000<br>00110000<br>001110000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | read or written. EB_B<br>ted.<br>ster supports EB_BE<br>les below, it must have<br>ng the default patterns<br>lefault in 64-bit implem<br>00000100<br>01000000<br>00001100<br>00001110<br>111111                                                                                                                                                                                                                                                                                                       | an EB_BE signal is<br>E lines are only valid<br>patterns other than<br>an input signal that<br>only.<br>eentations<br>00001000<br>10000000<br>00000011<br>000000111<br>000011111<br>0111111                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 0 |                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | address phase is the f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | irst address phase of                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 0 | Assertion of this signal indicates the address phase is the last address phase of a burst. Note that the time for assertion of EB_BLast is determined by use of EB_Burst, EB_BFirst, and EB_BLen. EB_BLast is always valid. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| 0 | This signal is a                                                                                                                                                                                                            | phases) of the burst.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|   | 0                                                                                                                                                                                                                           | asserted, the as<br>while EB_AVaDuring bursts a<br>During singlet<br>the default one<br>makes it possibleByte<br>000000010001000011000000111000001110000011110000111111101111111011111111EB_BE<br>SignalEB_BE[0]EB_BE[1]EB_BE[2]EB_BE[2]EB_BE[3]EB_BE[3]EB_BE[4]^aEB_BE[5]^aEB_BE[6]^aEB_BE[6]^aEB_BE[7]^aOAssertion of th<br>a burst. Note th<br>EB_Burst, EB_OAssertion of th<br>a burst. Note th<br>EB_BLen[1:0]<br>This signal is a<br>Image: content of the signal is a<br> | asserted, the associated byte is being<br>while EB_AValid is asserted.During bursts all lines must be asserted.During single transactions, if the mathe default ones listed in the two table<br>makes it possible to force it into usinByte enables supported by of<br>00000001000000001000000001000000001Ouring single transactions, if the mathe default ones listed in the two table<br>makes it possible to force it into usinByte enables supported by of<br>000000000000000000000000000000000000 | Ouring bursts all lines must be asserted.         During single transactions, if the master supports EB_BE to default ones listed in the two tables below, it must have makes it possible to force it into using the default patterns.         Byte enables supported by default in 64-bit implem 00000001 0000000 01100000 01000000         11000000 0110000 00001100         111100000 011110000 00001100         11110000 0111111         11111000 0001111         1111100 011111         1111100 011111         1111100         1111100         111100         11111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         1111         11100       01 |  |  |

## Table 2 EC Interface Signals (Continued)

| Signal Name                                    | Dir | Description                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EB_Burst                                       | 0   | Assertion of this signal indicates that the current address phase is for a cache fill or a write burst. EB_Burst is always valid.                                                                                                                                                                                                                           |
| EB_EWBE                                        | I   | Indicates that the external write buffers are empty. When this signal is deasserted because of a write from the core, it must be deasserted in the same cycle that the write is accepted (one cycle after the corresponding EB_WDRdy is asserted). See Section 4, "External Write Buffers" on page 30 for more details.                                     |
| EB_Instr                                       | 0   | Assertion of this signal indicates that the address is for an instruction fetch as opposed to a data read. EB_Instr is only valid when EB_AValid is asserted.                                                                                                                                                                                               |
| EB_RBErr                                       | Ι   | Bus error indicator for read transactions. EB_RBErr is always valid. Only assert it in the same cycle that the corresponding EB_RdVal is asserted.                                                                                                                                                                                                          |
| EB_RData[31:0]<br>EB_RData[63:32] <sup>a</sup> | Ι   | Read data bus. Valid at the end of a read data phase (on the rising clock edge where EB_RdVal is sampled asserted).                                                                                                                                                                                                                                         |
| EB_RdVal                                       | Ι   | Assertion of this signal indicates that the slave is driving read data on EB_RData (it ends a read data phase). EB_RdVal must always be valid. EB_RdVal must never be asserted until after the corresponding EB_ARdy is sampled asserted.                                                                                                                   |
| EB_SBlock                                      | SI  | When this signal is asserted, sub-block ordering is used for addressing bursts.<br>When this signal is deasserted, sequential addressing is used. See Section 3.7,<br>"Burst Transactions" on page 25 for details.                                                                                                                                          |
| EB_WBErr                                       | Ι   | Bus error indicator for write transactions. EB_WBErr is always valid. Only assert it in the cycle following an asserted sample of the corresponding EB_WDRdy.                                                                                                                                                                                               |
| EB_WData[31:0]<br>EB_WData[63:32] <sup>a</sup> | 0   | Write data bus. Kept unchanged and stable during a write data phase until the write data phase ends (the positive clock edge following an asserted sample of EB_WDRdy).                                                                                                                                                                                     |
| EB_WDRdy                                       | Ι   | Assertion of this signal indicates that the slave is ready to process a write; it ends<br>a write data phase and the EB_WData can change after the positive clock edge<br>that follows the positive clock edge where EB_WDRdy is sampled asserted.<br>EB_WDRdy is not sampled until the rising edge where the corresponding<br>EB_ARdy is sampled asserted. |
| EB_Write                                       | 0   | Assertion of this signal indicates that the address phase is for a write.<br>Deassertion of this signal indicates that the address phase is for a read. This<br>signal is only valid when EB_AValid is asserted.                                                                                                                                            |
| EB_WWBE                                        | 0   | Assertion of this signal indicates that the master is waiting for external write<br>buffers to empty. EB_WWBE can be asserted when EB_EWBE is asserted, but<br>if EB_EWBE is deasserted and EB_WWBE is asserted, EB_EWBE must be<br>asserted eventually. See Section 4, "External Write Buffers" on page 30 for<br>more details.                            |

a. Optional. Only used in 64-bit implementations.

#### **3** Timing Diagrams

The following sections provide examples of typical EC interface timing.

#### 3.1 Single Read Transactions

Figure 2 shows the basic timing relationships between signals during a simple (fastest) read transaction. When the master is ready to begin a bus transaction (cycle 3), the address is driven on EB\_A, the associated control information is driven on EB\_Instr, EB\_Burst, EB\_BFirst, EB\_BLast, EB\_BLen, EB\_Write, and EB\_BE, and EB\_AValid is asserted. On the same rising clock edge that these signals are driven out (end of cycle 2), the EB\_ARdy signal state is sampled. If EB\_ARdy is sampled deasserted, the master maintains the transaction values on the previously mentioned signals. The master continues driving valid and stable values on these interface signals until the rising clock edge following the one that the EB\_ARdy signal is sampled asserted.

Starting in the same cycle as the read transaction is initiated, the master samples EB\_RdVal, EB\_RData, and EB\_RBErr. These signals are sampled on each rising clock edge until the EB\_RdVal signal is sampled asserted. The data values sampled with this asserted EB\_RdVal are considered valid. However, if EB\_RBErr was sampled asserted in same cycle, the transaction is considered failed.

Note that the data phase cannot end earlier than the corresponding address phase. EB\_ARdy must be sampled asserted at least one clock cycle before the corresponding EB\_RdVal is sampled asserted.



Figure 2 Fastest Single Read Transaction Timing

Figure 3 shows an example of a read transaction with three wait states in the data phase (indicated by the deassertion of EB\_RdVal for three clock cycles). EB\_RdVal is sampled deasserted on the rising edges at the beginning of cycles 4, 5, and 6 and then is asserted on cycle 7.



Figure 3 Single Read Transaction Timing (3 Data Wait States)

#### **3.2 Single Write Transactions**

Figure 4 shows a zero wait state (fastest) write transaction. Like the read transaction when a write request is issued (cycle 3), the address and control information for the transaction are driven on EB\_A, EB\_Instr, EB\_Burst, EB\_BFirst, EB\_BLast, EB\_BLen, EB\_Write, and EB\_BE. These signals remain unchanged until the rising clock edge after the EB\_ARdy signal is sampled asserted.

The write data is driven on the write data bus, EB\_WData, in same cycle as the address is driven on EB\_A. The write data is held on the bus until the rising clock edge after EB\_WDRdy is sampled asserted.

EB\_WBErr is sampled on the first rising clock edge after the rising clock edge that EB\_WDRdy is sampled asserted. If EB\_WBErr is asserted at this time, the bus transaction is considered failed.

Note that the data phase cannot end earlier than the corresponding address phase. EB\_WDRdy must be sampled asserted on the same clock edge or later than the clock edge where the corresponding EB\_ARdy is sampled asserted.



Figure 4 Fastest Single Write Transaction Timing

Figure 5 shows an example of a write transaction with four data wait states, indicated by the deassertion of the EB\_WDRdy signal. EB\_WDRdy is deasserted for four clock cycles and then asserted. Note that the address phase is prolonged by one clock cycle because EB\_ARdy is deasserted for one clock cycle (sampled deasserted at the end of cycle 2).



Figure 5 Single Write Transaction Timing (1 Address Wait State and 4 Data Wait States)

#### 3.3 Back-to-back Read Transactions

Figure 6 shows an example of two consecutive read transactions, which shows the ability to pipeline read addresses independent of data wait states. The pipeline depth is implementation specific. Through manipulation of the EB\_ARdy signal, the slave can limit the depth of the address pipelining.



Figure 6 Back-to-back Read Transaction Timing

#### **3.4 Back-to-back Write Transactions**

Figure 7 shows an example of two consecutive write transactions. Similar to the read transactions, pipelining of write addresses can occur regardless of data wait states.



Figure 7 Back-to-back Write Transaction Timing

#### 3.5 Read Transaction Followed by a Write Transaction

Figure 8 shows the relationship between a read transaction and a subsequent write transaction. A write transaction following a read transaction behaves as described for the single write transaction. Completion of these transactions out of order is allowed.





EC<sup>™</sup> Interface Specification, Revision 1.05



Figure 9 shows an example of a read transaction followed by a write transaction where the write transaction is completed prior to the read transaction (out of order).

Figure 9 Read Transaction Followed by a Write Transaction with Reordering

#### 3.6 Write Transaction Followed by a Read Transaction

Figure 10 shows an example of a write transaction followed by a read. As in the case of a write following a read, a read transaction following a write transaction is not affected by the behavior of the write transaction. Completion of these transactions out of order is allowed.





Figure 11 shows an example of a write transaction followed by a read transaction where the read transaction is completed prior to the write transaction (out of order).



Figure 11 Write Transaction Followed by a Read Transaction with Reordering

#### **3.7 Burst Transactions**

A burst transaction initiates the transfer of multiple related transfers. Read bursts are used to read data to be placed in the instruction or data cache. Write bursts are used to empty the contents of the write buffers.

Note that initiated bursts are always completed. The burst transaction cannot be aborted before reaching the burst beat count (indicated by EB\_BLen) except in the case where the EC interface is reset.

EB\_Burst is asserted during the entire burst address sequence. EB\_BFirst is driven asserted during the first address phase of the burst and is deasserted with each of the remaining address phases. EB\_BLast is driven asserted during the last address phase and is deasserted with all prior address phases. Apart from EB\_Burst, EB\_BFirst and EB\_BLast behavior, and the deterministic address sequence, the multiple transfers of a burst transaction behave like that of back-to-back single transactions, which simplifies interfacing to systems that do not support burst transactions. Note that it is possible in the presence of data wait states, for all of the burst address phases to complete before the first data phase of the burst (or even of a preceding transaction) has completed. If this behavior is undesirable, EB\_ARdy can be used to control the pace at which the addresses are transferred.

Note that EB\_AValid cannot be deasserted between address phases within a burst and that all bits in EB\_BE must be asserted in all address phases within a burst.

Figure 12 shows an example of a read burst transaction. EB\_BLen indicates the length of the burst (see Section 2, "Signal List" on page 6 for further information on EB\_BLen). The data requested is always an aligned block according to the EB\_BLen signal. The order of the words within the block varies depending on which word in the block is being requested and the value of EB\_SBlock (see Table 3 through Table 6 for further information on the refill scheme).



Figure 12 Burst Read Transaction Timing

Table 3 through Table 6 show the possible sequences for the least significant address bits during a burst. Note that addresses within a write burst will always be sequential and ascending matching the first rows in the following tables.

| Req Word<br>(DWord <sup>a</sup> )<br>Address | EB_A[3:2] (EB_A[4:3] <sup>a</sup> ) Sequence |   |   |   |  |  |  |
|----------------------------------------------|----------------------------------------------|---|---|---|--|--|--|
| 0                                            | 0                                            | 1 | 2 | 3 |  |  |  |
| 1                                            | 1                                            | 2 | 3 | 0 |  |  |  |
| 2                                            | 2                                            | 3 | 0 | 1 |  |  |  |
| 3                                            | 3                                            | 0 | 1 | 2 |  |  |  |

Table 3 Burst Order for Sequential Ordering (4 Beat Bursts)

a. Optional. Only used in 64-bit implementations.

#### Table 4 Burst Order for Sub-block Ordering (4 Beat Bursts)

| Req Word<br>(DWord <sup>a</sup> )<br>Address | EB_A[3:2] (EB_A[4:3] <sup>a</sup> ) Sequence |   |   |   |  |  |  |
|----------------------------------------------|----------------------------------------------|---|---|---|--|--|--|
| 0                                            | 0                                            | 1 | 2 | 3 |  |  |  |
| 1                                            | 1                                            | 0 | 3 | 2 |  |  |  |
| 2                                            | 2                                            | 3 | 0 | 1 |  |  |  |
| 3                                            | 3                                            | 2 | 1 | 0 |  |  |  |

a. Optional. Only used in 64-bit implementations.

#### Table 5 Burst Order for Sequential Ordering (8 Beat Bursts)

| Req Word<br>(DWord <sup>a</sup> )<br>Address | EB_A[4:2] (EB_A[5:3] <sup>a</sup> ) Sequence |   |   |   |   |   |   |   |
|----------------------------------------------|----------------------------------------------|---|---|---|---|---|---|---|
| 0                                            | 0                                            | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 1                                            | 1                                            | 2 | 3 | 4 | 5 | 6 | 7 | 0 |
| 2                                            | 2                                            | 3 | 4 | 5 | 6 | 7 | 0 | 1 |
| 3                                            | 3                                            | 4 | 5 | 6 | 7 | 0 | 1 | 2 |
| 4                                            | 4                                            | 5 | 6 | 7 | 0 | 1 | 2 | 3 |
| 5                                            | 5                                            | 6 | 7 | 0 | 1 | 2 | 3 | 4 |
| 6                                            | 6                                            | 7 | 0 | 1 | 2 | 3 | 4 | 5 |
| 7                                            | 7                                            | 0 | 1 | 2 | 3 | 4 | 5 | 6 |

a. Optional. Only used in 64-bit implementations.

| Req Word<br>(DWord <sup>a</sup> )<br>Address | EB_A[4:2] (EB_A[5:3] <sup>a</sup> ) Sequence |   |   |   |   |   |   |   |
|----------------------------------------------|----------------------------------------------|---|---|---|---|---|---|---|
| 0                                            | 0                                            | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 1                                            | 1                                            | 0 | 3 | 2 | 5 | 4 | 7 | 6 |
| 2                                            | 2                                            | 3 | 0 | 1 | 6 | 7 | 4 | 5 |
| 3                                            | 3                                            | 2 | 1 | 0 | 7 | 6 | 5 | 4 |
| 4                                            | 4                                            | 5 | 6 | 7 | 0 | 1 | 2 | 3 |
| 5                                            | 5                                            | 4 | 7 | 6 | 1 | 0 | 3 | 2 |
| 6                                            | 6                                            | 7 | 4 | 5 | 2 | 3 | 0 | 1 |
| 7                                            | 7                                            | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|                                              |                                              | - |   |   |   |   |   |   |

Table 6 Burst Order for Sub-block Ordering (8 Beat Bursts)

a. Optional. Only used in 64-bit implementations.

Figure 13 shows a burst write. Burst write transactions are used to empty write buffers. Write burst addresses always start at the lowest address of an address block according to the EB\_BLen indication.

Note that like single transactions, burst read and write transactions can complete out of order. Burst reads can overtake burst writes and vice versa.



Figure 13 Burst Write Transaction Timing

#### **4** External Write Buffers

Some systems might have external write buffers to increase bus efficiency and system performance. The EC interface has a simple two-signal protocol that allows the master to have some control over the external write buffers. When it asserts EB\_WWBE, the master signals that it is waiting for EB\_EWBE (External Write Buffers Empty) to be asserted. The master uses EB\_EWBE to ensure that all pending writes have completed before it begins a new transaction.

The EB\_WWBE/EB\_EWBE interface can be used to make synchronization harder by forcing the flush of the external write buffers. This is a system/SW design issue - a decision must be made in determining what the system does when a synchronizing instruction is executed. In many systems EB\_WWBE can be left unconnected while EB\_EWBE is tied HIGH.

If no external write buffers exist, tie EB\_EWBE HIGH. If synchronization in a system does not require the write buffers to flush - tie EB\_EWBE HIGH and leave EB\_WWBE unconnected for maximum system performance.

Note that EB\_WWBE is not used to ensure coherency. If a write transaction is to the external write buffer, the master can generate a read request to the given address without asserting EB\_WWBE (because the master has no knowledge of the external write buffers). Therefore any write buffers in the system must maintain coherency with reads. EB\_WWBE is not needed in all systems. If the external write buffers always will empty by time there is no need. However if the external write buffers will not empty unless they are forced to EB\_WWBE can be used as an indication of when to force the flush.

In Figure 14 and Figure 15 two examples of EB\_EWBE signalling are shown. When there are no wait states on the write transactions (Figure 14) EB\_EWBE must be deasserted when EB\_AValid and EB\_Write is asserted or if the external write buffer are non-empty due to previous write transactions. In Figure 14 EB\_EWBE is asserted in cycle 7 as no writes are received and the external write buffers are empty.

In Figure 15 two wait states are inserted in the data phase. EB\_EWBE is deasserted one cycle after assertion of EB\_WDRdy. In the example EB\_WDRdy is asserted due to acceptance of a new write transaction and EB\_EWBE is deasserted in cycle 5 as EB\_WDRdy was asserted in cycle 4. In Figure 15 EB\_EWBE is asserted in cycle 8 as no writes are received and the external write buffers are empty.

Note that the number of cycles where EB\_EWBE is deassserted will depend on the actual implementation of the external write buffers.



Figure 14 Example of EB\_EWBE signalling when no wait states on address/data.



Figure 15 Example of EB\_EWBE signalling when no wait states on address and two wait states on data.

## A Endianess

The EC interface has no signal that indicates little- or big-endian operation. If the slave requires this information, for example, to generate the lower address bits that are not supplied with the EC interface, consult the documentation that comes with the core.

To help understand the use of endianess, Table 7 and Table 8 show some cases of how stores appear on the EC interface in little-endian and big-endian mode in a 32-bit and a 64-bit implementation of the EC interface.

|                                     | Internal  | Big-er     | ndian      | Little-e   | endian     |  |  |  |
|-------------------------------------|-----------|------------|------------|------------|------------|--|--|--|
|                                     | Addr[1:0] | EB_D[31:0] | EB_BE[3:0] | EB_D[31:0] | EB_BE[3:0] |  |  |  |
| lui t0, 0x789a<br>ori t0, t0, 0xbcd | le        |            |            |            |            |  |  |  |
| sb t0, 0x0(r0)                      | 0         | 0xdeXXXXXX | 1000       | 0xXXXXXXde | 0001       |  |  |  |
| sb t0, 0x1(r0)                      | 1         | 0xXXdeXXXX | 0100       | 0xXXXXdeXX | 0010       |  |  |  |
| sb t0, 0x2(r0)                      | 2         | 0xXXXXdeXX | 0010       | 0xXXdeXXXX | 0100       |  |  |  |
| sb t0, 0x3(r0)                      | 3         | 0xXXXXXXde | 0001       | 0xdeXXXXXX | 1000       |  |  |  |
| sh t0, 0x0(r0)                      | 0         | 0xbcdeXXXX | 1100       | 0xXXXXbcde | 0011       |  |  |  |
| sh t0, 0x2(r0)                      | 2         | 0xXXXXbcde | 0011       | 0xbcdeXXXX | 1100       |  |  |  |
| swl t0, 0x1(r0)                     | 1         | 0xXX789abc | 0111       | 0xXXXX789a | 0011       |  |  |  |
| swl t0, 0x2(r0)                     | 2         | 0xXXXX789a | 0011       | 0xXX789abc | 0111       |  |  |  |
| swr t0, 0x1(r0)                     | 1         | 0xbcdeXXXX | 1100       | 0x9abcdeXX | 1110       |  |  |  |
| swr t0, 0x2(r0)                     | 2         | 0x9abcdeXX | 1110       | 0xbcdeXXXX | 1100       |  |  |  |
| sw t0, 0x0(r0)                      | 0         | 0x789abcde | 1111       | 0x789abcde | 1111       |  |  |  |

Table 7 Endian Examples, 32-bit Implementation

#### Table 8 Endian Examples, 64-bit Implementation

|                                                                                                                     | Internal  |                           |          |                       |                | Little-endian |  |
|---------------------------------------------------------------------------------------------------------------------|-----------|---------------------------|----------|-----------------------|----------------|---------------|--|
|                                                                                                                     | Addr[2:0] | EB_D[63:0] EB_BI<br>[7:0] |          | EB_D[63:0]            | EB_BE<br>[7:0] |               |  |
| lui t0, 0x0123<br>ori t0, t0, 0x456<br>dsll t0, t0, 16<br>ori t0, t0, 0x89a<br>dsll t0, t0, 16<br>ori t0, t0, 0xcde | ab        |                           |          |                       |                |               |  |
| sb t0, 0x0(r0)                                                                                                      | 0         | 0xefXXXXXXXXXXXXXXXX      | 1000000  | 0xXXXXXXXXXXXXXXXX    | 00000001       |               |  |
| sb t0, 0x1(r0)                                                                                                      | 1         | 0xXXefXXXXXXXXXXXXX       | 01000000 | 0xXXXXXXXXXXXXXXXEfXX | 00000010       |               |  |
| sb t0, 0x2(r0)                                                                                                      | 2         | 0xXXXXefXXXXXXXXXXX       | 00100000 | 0xXXXXXXXXXXXefXXXX   | 00000100       |               |  |
| sb t0, 0x3(r0)                                                                                                      | 3         | 0xXXXXXXXefXXXXXXXX       | 00010000 | 0xXXXXXXXXXefXXXXXX   | 00001000       |               |  |
| sb t0, 0x4(r0)                                                                                                      | 4         | 0xXXXXXXXXXefXXXXXX       | 00001000 | 0xXXXXXXefXXXXXXXX    | 00010000       |               |  |
| sb t0, 0x5(r0)                                                                                                      | 5         | 0xXXXXXXXXXXefXXXX        | 00000100 | 0xXXXXefXXXXXXXXXXX   | 00100000       |               |  |

EC<sup>™</sup> Interface Specification, Revision 1.05

|                 | Internal<br>Addr[2:0] | Big-endian            |                | Little-endian        |                |
|-----------------|-----------------------|-----------------------|----------------|----------------------|----------------|
|                 |                       | EB_D[63:0]            | EB_BE<br>[7:0] | EB_D[63:0]           | EB_BE<br>[7:0] |
| sb t0, 0x6(r0)  | 6                     | 0xXXXXXXXXXXXXXXXefXX | 00000010       | 0xXXefXXXXXXXXXXXXXX | 01000000       |
| sb t0, 0x7(r0)  | 7                     | 0xXXXXXXXXXXXXXXXX    | 00000001       | 0xefXXXXXXXXXXXXXXXX | 10000000       |
| sh t0, 0x0(r0)  | 0                     | 0xcdefXXXXXXXXXXXXX   | 11000000       | 0xXXXXXXXXXXXXXCdef  | 00000011       |
| sh t0, 0x2(r0)  | 2                     | 0xXXXXcdefXXXXXXXX    | 00110000       | 0xXXXXXXXXCdefXXXX   | 00001100       |
| sh t0, 0x4(r0)  | 4                     | 0xXXXXXXXXCdefXXXX    | 00001100       | 0xXXXXcdefXXXXXXXX   | 00110000       |
| sh t0, 0x6(r0)  | 6                     | 0xXXXXXXXXXXXXXCdef   | 00000011       | 0xcdefXXXXXXXXXXXXX  | 11000000       |
| swl t0, 0xl(r0) | 1                     | 0xXX89abcdXXXXXXXX    | 01110000       | 0xXXXXXXXXXXXX89ab   | 00000011       |
| swl t0, 0x2(r0) | 2                     | 0xXXXX89abXXXXXXXX    | 00110000       | 0xXXXXXXXXX89abcd    | 00000111       |
| swl t0, 0x5(r0) | 5                     | 0xXXXXXXXXXX89abcd    | 00000111       | 0xXXXX89abXXXXXXXX   | 00110000       |
| swl t0, 0x6(r0) | 6                     | 0xXXXXXXXXXXXX89ab    | 00000011       | 0xXX89abcdXXXXXXXX   | 01110000       |
| swr t0, 0x1(r0) | 1                     | 0xcdefXXXXXXXXXXXXX   | 11000000       | 0xXXXXXXXXabcdefXX   | 00001110       |
| swr t0, 0x2(r0) | 2                     | 0xabcdefXXXXXXXXXXX   | 11100000       | 0xXXXXXXXXCdefXXXX   | 00001100       |
| swr t0, 0x5(r0) | 5                     | 0xXXXXXXXXCdefXXXX    | 00001100       | 0xabcdefXXXXXXXXXXX  | 11100000       |
| swr t0, 0x6(r0) | 6                     | 0xXXXXXXXXXabcdefXX   | 00001110       | 0xcdefXXXXXXXXXXXXX  | 11000000       |
| sw t0, 0x0(r0)  | 0                     | 0x89abcdefXXXXXXXX    | 11110000       | 0xXXXXXXXX89abcdef   | 00001111       |
| sw t0, 0x4(r0)  | 4                     | 0xXXXXXXXX89abcdef    | 00001111       | 0x89abcdefXXXXXXXX   | 11110000       |
| sdl t0, 0x1(r0) | 1                     | 0xXX0123456789abcd    | 01111111       | 0xXXXXXXXXXXXXXX0123 | 00000011       |
| sdl t0, 0x2(r0) | 2                     | 0xXXXX0123456789ab    | 00111111       | 0xXXXXXXXXXX012345   | 00000111       |
| sdl t0, 0x3(r0) | 3                     | 0xXXXXXX0123456789    | 00011111       | 0xXXXXXXXX01234567   | 00001111       |
| sdl t0, 0x4(r0) | 4                     | 0xXXXXXXXX01234567    | 00001111       | 0xXXXXXX0123456789   | 00011111       |
| sdl t0, 0x5(r0) | 5                     | 0xXXXXXXXXXXX012345   | 00000111       | 0xXXXX0123456789ab   | 00111111       |
| sdl t0, 0x6(r0) | 6                     | 0xXXXXXXXXXXXXXX0123  | 00000011       | 0xXX0123456789abcd   | 01111111       |
| sdr t0, 0x1(r0) | 1                     | 0xcdefXXXXXXXXXXXXX   | 11000000       | 0x23456789abcdefXX   | 11111110       |
| sdr t0, 0x2(r0) | 2                     | 0xabcdefXXXXXXXXXX    | 11100000       | 0x456789abcdefXXXX   | 11111100       |
| sdr t0, 0x3(r0) | 3                     | 0x89abcdefXXXXXXXX    | 11110000       | 0x6789abcdefXXXXXX   | 11111000       |
| sdr t0, 0x4(r0) | 4                     | 0x6789abcdefXXXXXX    | 11111000       | 0x89abcdefXXXXXXXX   | 11110000       |
| sdr t0, 0x5(r0) | 5                     | 0x456789abcdefXXXX    | 11111100       | 0xabcdefXXXXXXXXXX   | 11100000       |
| sdr t0, 0x6(r0) | 6                     | 0x23456789abcdefXX    | 11111110       | 0xcdefXXXXXXXXXXXXX  | 11000000       |
| sd t0, 0x0(r0)  | 0                     | 0x0123456789abcdef    | 11111111       | 0x0123456789abcdef   | 11111111       |

#### **B** Lower Address Bit Generation

Figure 16 shows a Verilog example of how the lower address bits can be generated for use with a SysAD interface. Note that this case requires that only the default EB\_BE patterns are used.

Figure 16 Example of Generating Low Address Bit

## C Revision History

| Revision | Date     | Comments                                                                                      |
|----------|----------|-----------------------------------------------------------------------------------------------|
| 01.00    | 00/03/01 | First official release.                                                                       |
| 01.01    | 00/07/04 | Added revision history and changed page 2, footer and the setup for conversion to pdf format. |
| 01.02    | 00/10/09 | Removed copyright notice from footer.                                                         |
| 01.03    | 00/12/18 | Converted document to new template. Editorial changes only.                                   |
| 01.04    | 01/8/17  | Added EB_EWBE waveforms and description.                                                      |
| 01.05    | 02/02/25 | Minor addition to EB_EWBE/EB_WWBE description.                                                |